<template>
  <div class="todo-footer">
    <label>
      <input type="checkbox" v-model="isAll"/>
    </label>
    <span> <span>已完成{{doneCount}}</span> / 全部{{total}} </span>
    <button class="btn btn-danger" @click="deleteAllDoneTodo">清除已完成任务</button>
  </div>
</template>

<script>
export default {
  name: "Footer",
	props:['todos','checkAll','deleteAllDoneTodo'],
	computed:{
		// 总数（计算属性）
		total(){
			return this.todos.length
		},
		// 已完成总数（计算属性）
		doneCount(){
			// 第一种计算已完成总数的方式
			/* let n = 0
			this.todos.forEach(todo => {
				if(todo.done){
					n++
				}
			});
			return n */

			// 第二种计算已完成总数的方式
			/* return this.todos.filter((todo)=>{
				return todo.done === true
			}).length */

			// 第三种用reduce，最简便的方式去写
			// reduce能干的活：①条件统计 ②条件求和 ③筛选最值
			return this.todos.reduce((pre,current)=> pre + (current.done ? 1 : 0) ,0)
		},
		// 是否全选（计算属性）
		isAll:{
			get(){
				return this.todos.every((todo)=>{
					return todo.done
				})
			},
			set(checked){
				this.checkAll(checked)
			}
		},
	},
};
</script>

<style scoped>
/*footer*/
.todo-footer {
  height: 40px;
  line-height: 40px;
  padding-left: 6px;
  margin-top: 5px;
}

.todo-footer label {
  display: inline-block;
  margin-right: 20px;
  cursor: pointer;
}

.todo-footer label input {
  position: relative;
  top: -1px;
  vertical-align: middle;
  margin-right: 5px;
}

.todo-footer button {
  float: right;
  margin-top: 5px;
}
</style>